//
//  NewFeatureViewController.swift
//  weibo
//
//  Created by 张衡 on 15/8/1.
//  Copyright © 2015年 张衡. All rights reserved.
//

import UIKit

private let reuseIdentifier = "Cell"

class NewFeatureViewController: UICollectionViewController {
    
    /// 图像总数
    private let imageCount = 4
    
    /// 布局属性 （collectionView 诞生必带的属性）
    private let layout = HMFlowLayout()
    
    // 没有 override，因为 collectionView 的指定的构造函数是带 layout 的
    init() {
        super.init(collectionViewLayout: layout) // 初始化时就指定layout
    }

    required init?(coder aDecoder: NSCoder) {
        
        // 本类 禁止用 sb 开发 - 纯代码开发用这个，考虑因素少，风险小
        // fatalError("init(coder:) has not been implemented")
        
        // 本类 允许用 sb 开发，有些公司是混合开发！需要考虑的因素多，都需要测试才行！
        super.init(coder: aDecoder)
    }


    override func viewDidLoad() {
        super.viewDidLoad()

        // Uncomment the following line to preserve selection between presentations
        // self.clearsSelectionOnViewWillAppear = false

        //  为collectionview注册cell（自定义cell）
        self.collectionView!.registerClass(NewFeatureCell.self, forCellWithReuseIdentifier: reuseIdentifier)

        // Do any additional setup after loading the view.
    }

  

    // MARK: UICollectionViewDataSource
    // 1、 有几个项，获取数据远，确认有cell
    override func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        return imageCount
    }
    // 2.是准备cell布局，在最下面
    // 3、 获取每个索引对应的cell
    override func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCellWithReuseIdentifier(reuseIdentifier, forIndexPath: indexPath) as! NewFeatureCell
    
        cell.imageIndex = indexPath.item //  用cell自有的indexPath（0-3共4个）给自定义cell 的图像索引imageIndex 属性 赋值，用来拼接图片名字
        return cell
    }
    
    
    /// 完成显示 cell - indexPath 是之前消失 cell 的 indexPath （代理方法）
    override func collectionView(collectionView: UICollectionView, didEndDisplayingCell cell: UICollectionViewCell, forItemAtIndexPath indexPath: NSIndexPath) {
        
        // 获取当前显示的 indexPath
        let path = collectionView.indexPathsForVisibleItems().last!
        
        // 判断是否是末尾的 indexPath
        if path.item == imageCount - 1 {
            // 拿到cell播放动画
            let cell = collectionView.cellForItemAtIndexPath(path) as! NewFeatureCell
            cell.startButtonAnim()
        }
    }



 
    
    
    
    
    /// 新特性的 cell  （两个类放在一起）
    class NewFeatureCell: UICollectionViewCell {
        
        /// 图像索引 - 私有属性，在同一个文件中，是允许访问的！
        // 虽然复用，过一遍自己的东西，拿到自己该有的特性
        private var imageIndex: Int = 0 {
            didSet {
                iconView.image = UIImage(named: "new_feature_\(imageIndex + 1)")
                startButton.hidden = true
            }
        }
        
        func clickStartButton() {
            // print("开始!!!")
            NSNotificationCenter.defaultCenter().postNotificationName(HMRootViewControllerSwitchNotification, object: true)
        }
        
        /// 开始按钮动画
        private func startButtonAnim() {
            
            startButton.hidden = false
            startButton.transform = CGAffineTransformMakeScale(0, 0)
            // 禁用按钮操作
            startButton.userInteractionEnabled = false
            
            UIView.animateWithDuration(1.2, delay: 0, usingSpringWithDamping: 0.8, initialSpringVelocity: 10, options: UIViewAnimationOptions(rawValue: 0), animations: { () -> Void in
                
                // 恢复默认形变
                self.startButton.transform = CGAffineTransformIdentity
                
                }) { (_) -> Void in
                    // 启用按钮点击
                    self.startButton.userInteractionEnabled = true
            }
        }
        
        // MARK: - 设置 UI ，新建cell时，设置内部元素
        override init(frame: CGRect) {
            super.init(frame: frame)
            // 纯代码调用
            prepareUI()
        }
        
        required init?(coder aDecoder: NSCoder) {
            super.init(coder: aDecoder)
            // storyboard调用
            prepareUI()
        }
        
        
        // 设置cell内部的元素
        private func prepareUI() {
            // 添加控件 - 建议都加载 contentView 上
            contentView.addSubview(iconView)
            contentView.addSubview(startButton)
            
            // 自动布局 约束加到共同的父视图上
            iconView.translatesAutoresizingMaskIntoConstraints = false
            contentView.addConstraints(NSLayoutConstraint.constraintsWithVisualFormat("H:|-0-[subview]-0-|", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: ["subview": iconView]))
            contentView.addConstraints(NSLayoutConstraint.constraintsWithVisualFormat("V:|-0-[subview]-0-|", options: NSLayoutFormatOptions(rawValue: 0), metrics: nil, views: ["subview": iconView]))
            
            startButton.translatesAutoresizingMaskIntoConstraints = false
            contentView.addConstraint(NSLayoutConstraint(item: startButton, attribute: NSLayoutAttribute.CenterX, relatedBy: NSLayoutRelation.Equal, toItem: contentView, attribute: NSLayoutAttribute.CenterX, multiplier: 1.0, constant: 0))
            contentView.addConstraint(NSLayoutConstraint(item: startButton, attribute: NSLayoutAttribute.Bottom, relatedBy: NSLayoutRelation.Equal, toItem: contentView, attribute: NSLayoutAttribute.Bottom, multiplier: 1.0, constant: -160))
        }
        
    // MARK: - 懒加载控件
    private lazy var iconView = UIImageView()
    private lazy var startButton: UIButton = {
        let button = UIButton()
            
        button.setBackgroundImage(UIImage(named: "new_feature_finish_button"), forState: UIControlState.Normal)
        button.setBackgroundImage(UIImage(named: "new_feature_finish_button_highlighted"), forState: UIControlState.Highlighted)
        button.setTitle("开始体验", forState: UIControlState.Normal)
        // 根据背景图片自动调整大小
        button.sizeToFit()
            
        // 提示: 按钮的隐藏属性会因为复用工作不正常
//        button.hidden = true
        
        button.addTarget(self, action: "clickStartButton", forControlEvents: UIControlEvents.TouchUpInside)
            
        return button
        }()
    }
    

    /// 自定义流水布局
    private class HMFlowLayout: UICollectionViewFlowLayout {
        
        // UICollectionViewFlowLayout : UICollectionViewLayout ->func prepareLayout() 获取数量后，准备cell前 ，调用获得布局信息
        
        // 2. 如果还没有设置 layout，获取数量之后，准备cell之前，会被调用一次
        // 准备布局属性
        private override func prepareLayout() {
            
            itemSize = collectionView!.bounds.size
            minimumInteritemSpacing = 0
            minimumLineSpacing = 0
            scrollDirection = UICollectionViewScrollDirection.Horizontal
            
            collectionView?.pagingEnabled = true
            collectionView?.showsHorizontalScrollIndicator = false
            collectionView?.bounces = false
        }
    }
    
    
}
